PORT-BASED PACKET FILTER 



FIELD 

This invention relates generally to communication between computers in a 
5 network and more particularly to filtering network packets based on the associated 

port. 

COPYRIGHT NOTICE/PERMISSION 

A portion of the disclosure of this patent document contains material that is 
1 0 subject to copyright protection. The copyright owner has no objection to the facsimile 
reproduction by anyone of the patent document or the patent disclosure as it appears 
in the Patent and Trademark Office patent file or records, but otherwise reserves all 
copyright rights whatsoever, The following notice applies to the software and data as 
described below and in the drawings hereto: Copyright © Intel, Incorporated, 2000. 
1 5 All Rights Reserved. 



BACKGROUND 

Modern computers are often connected via networks, so that they can 
communicate with each other and share information. The Internet is an example of 

20 one such network. Computers send information to each other on the network via 
packets, which are collections of related data. In some networks, source computers 
routinely broadcast packets to all computers attached to the network, even though the 
intended destination is only one computer, or perhaps a subset of the computers. In 
other networks, the source and destination computers are not directly connected to 

25 each other, so a packet might need to travel through multiple computers before 
reaching its final destination. In both of these types of networks, a computer can 
receive large numbers of packets for which it is not the intended destination. 

Since it is inefficient for a networked computer to waste its time and energy 
examining large numbers of packets for which it is not the intended destination, a 
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networked computer typically offloads this function to a network adapter, through 
which the computer (called the host computer) attaches to the network. It is thus the 
job of the network adapter to examine each received packet, determine its intended 
destination, and present the received packet to the adapter's host computer only if the 
5 packet is intended for it. Otherwise, the network adapter merely discards the packet or 
forwards it through the network. 

In order to save electricity, the host computer typically enters a power- 
managed state when it is not receiving packets. During a power-managed state, the 
host computer uses less electricity by powering down or reducing electricity to 
10 selected computer components. When the network adapter detects a packet for which 

the host computer is the final destination, the adapter sends the host a wake-up signal, 
which causes the host to return to its operational working state, so that the host is 
capable of processing the received packet, and so that other hosts on the network can 
access its resources, such as web pages, files, printers, applications or services. 

1 5 Unfortunately, unauthorized persons or programs (often called hackers) will 

probe the network to find hosts that are running applications or services that can be 
attacked. These hackers attempt to access the host computer by sending packets that 
contain the destination address of the host computer. Since the host network address 
matches the address in the packet, the network adapter sends the host a wake-up signal 

20 causing it to wake up, even if there are no applications or services running that can 

respond to the received packet. This wastes the host's time and energy and makes the 
host vulnerable to attack. Thus, there is a need for a solution that will protect a 
computer in a network from attack by unauthorized users and allow it to stay in the 
power-managed state until it receives a relevant packet. 

25 

BRIEF DESCRIPTION OF THE DRAWINGS 

Fig. 1 depicts a pictorial example of a network of computers that can be used 
to implement an embodiment of the invention. 
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Fig, 2 depicts a block diagram of the principal components of the network of 
computers illustrated in Fig. 1, according to an embodiment of the invention. 

Fig. 3 depicts a flowchart that describes a method at a host computer, 
according to an embodiment of the invention. 

5 Fig. 4 depicts a flowchart that describes a method at a port filter, according to 

an embodiment of the invention. 

Fig. 5 depicts a flowchart that describes a method at a port filter, according to 
an embodiment of the invention. 

10 DETAILED DESCRIPTION 

In the following detailed description of exemplary embodiments of the 
invention, reference is made to the accompanying drawings (where like numbers 
represent like elements), which form a part hereof, and in which is shown by way of 
illustration specific exemplary embodiments in which the invention may be practiced. 

15 These embodiments are described in sufficient detail to enable those skilled in the art 

to practice the invention, but other embodiments may be utilized and logical, 
mechanical, electrical, and other changes may be made without departing from the 
scope of the present invention. The following detailed description is, therefore, not to 
be taken in a limiting sense, and the scope of the present invention is defined only by 

20 the appended claims. 

Fig. 1 depicts an example of a network of computers that can be used to 
implement an embodiment of the invention. Host computer 1 10 is connected to 
remote computer 188 via network adapter 150 and network 160. 

Computer 110 includes processing unit 112, display device 114, and keyboard 
25 116. Processing unit 1 12 receives input data from input devices such as keyboard 116 

and network adapter 150 and presents output data to a user via display device 1 14, 
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Processing unit 112 also sends and receives packets of information across network 
160 to and from remote computer 188 via network adapter 150. 

Keyboard 1 16 is that part of computer 110 that resembles a typewriter 
keyboard and that enables a user to control particular aspects of the computer. 

5 Video-display terminal 1 14 is the visual output of computer 110. Video- 

display terminal 1 14 can be a cathode-ray tube (CRT) based video display well known 
in the art of computer hardware. But, with a portable or notebook-based computer, 
video display terminal 114 can be replaced with a liquid crystal display (LCD) based 
or gas, plasma-based, flat-panel display. 

10 To support storage and retrieval of data, processing unit 1 12 further includes 

diskette drive 122, hard-disk drive 123, and tape drive 124, which are interconnected 
with other components of processing unit 1 12. Although diskette drive 122, hard-disk 
drive 123, and tape drive 124 are shown incorporated into system unit 1 12, in another 
embodiment, they can be external to system unit 112, either connected directly, on a 

1 5 local area network (LAN), on network 1 60, or attached to remote computer 188. 

Diskette drive 122 and hard disk drive 123 are electro-mechanical devices that 
read from and write to magnetic disks, although any non- volatile storage devices can 
be used, such as CD-ROM drives. Tape drive 124 is an electro-mechanical device 
that reads from and writes to tape media. The tape media is typically a long, flat piece 
20 of flexible plastic influenced to hold information recorded in digital form. 

In one embodiment, the hardware of computer 1 10 is implemented using an 
IBM-compatible personal computer available from a number of vendors. But, an 
embodiment of the present invention can apply to any hardware configuration that 
allows filtering of packets, regardless of whether the computer is a complete, multi- 
25 user computer apparatus, a single-user workstation, or a network appliance that does 

not have non- volatile storage of its own. Computer 1 1 0 is thus a configuration that 
includes all functional components of a computer and its associated hardware. In 
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general, a typical computer system includes a console or processing unit such a 
processing unit 112, with one or more disk drives, a monitor such as video display 
terminal 114, and a keyboard such as keyboard 116, although one or more of these 
elements can be missing, and additional elements can be added. 

5 Network adapter 150 facilitates communication between computer 110 and 

network 160, which might be a local area network (LAN), wide area network (WAN), 
an intranet, or the Internet. The operation of network adapter 150 is further described 
with reference to Figs. 2, 4, and 5. 

Remote computer 188 can be implemented using any suitable computer. 
10 Remote computer 188 sends and receives packets across network 160. Although only 

one remote computer is shown, in another embodiment any number of remote 
computers can be present. 

Fig. 2 depicts a block diagram of the principal components of processing unit 
1 L2 of computer 110 and network adapter 150 attached via network 160 to remote 
15 computer 188. Computer 110 contains memory 230 connected via bus 255 to 

processor 240, diskette drive 122, hard-disk drive 123, and tape drive 124. Although 
the various components of Fig. 2 are drawn as single entities, each may consist of 
multiple entities and may exist at multiple levels. 

Memory 230 comprises a number of individual, volatile-memory modules that 
20 store segments of operating system and application software while power is supplied 
to computer 110. The software segments are partitioned into one or more virtual 
memory pages that each contains a uniform number of virtual memory addresses. 
When the execution of software requires more pages of virtual memory than can be 
stored within memory 230, pages that are not currently needed are swapped with the 
25 required pages, which are stored within non- volatile storage devices 122 or 123. 

Memory 230 is a type of memory designed such that the location of data stored in it is 
independent of the content. Also, any location in memory 230 can be accessed 
directly without needing to start from the beginning. 
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Memory 230 contains application 260, controller 262, and program 
information 264. Application 260 is an application or service in computer 1 10 that is 
capable of being associated with a network port number. A port number identifies a 
logical connection to a process, such as application 260, on computer 1 10 and enables 
5 packets of information to be sent via network 160 to this process. Although one 

application 260 is shown, in another embodiment multiple applications are present. 
Application 260 contains instructions capable of being executed by processor 240. 

Controller 262 manages the connection of application 260 to network 160 
through network adapter 150 using program information 264. Controller 262 contains 
10 instructions capable of being executed by processor 240. In another embodiment, 

controller 262 can be implemented by control circuitry though the use of logic gates, 
programmable logic devices, or other hardware components in lieu of a processor- 
based system. The operations of controller 262 are further described with reference to 
Fig. 3. 

15 Referring again to Fig. 2, program information 264 is used by controller 262 to 

program network adapter 150 to filter packets received from network 160. Upon 
receiving program information 264, network adapter 150 will send to host computer 
110 only the packets that meet the criteria specified in program information 264. In 
one embodiment, program information 264 contains instructions capable of being 

20 executed by network adapter 150. In another embodiment, program 264 contains data 
identifying the port numbers of applications within computer 110. Program 
information 264 is further described with reference to Figs. 3, 4, and 5. 

Processor 240 executes instructions and includes that portion of host computer 
110 that controls the operation of the entire computer system, including executing the 
25 arithmetical and logical functions contained in a particular computer program, such as 

application 260 and controller 262, in one embodiment. Although not depicted in Fig. 
2, processor 240 typically includes a control unit that organizes data and program 
storage in a computer memory and transfers data and other information between the 
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various part of the computer system. Processor 240 accesses data and instructions 
from and stores data to memory 230. 

Any appropriate processor can be utilized for processor 240. Although 
computer 1 10 is shown to contain only a single processor and a single system bus, the 
5 present invention applies equally to computers that have multiple processors and to 

computers that have multiple buses that each performs different functions in different 
ways. 

Network adapter 150 facilitates communication between computer 110 and 
network 160. Network 160 provides a user of computer 110 with a means of 
10 electronically communicating information, such as packets, with a remote computer or 
a network logical-storage device. In addition, in one embodiment, network 160 
supports distributed processing, which enables computer 1 10 to share a task with other 
computer systems linked to the network. 

Network adapter 150 contains networking device 272, pattern filter(s) 274, and 
15 port filter(s) 276. Although network adapter 150 is shown as separate from host 

computer 1 10, in another embodiment they are packaged together. 

Networking device 272 sends and receives packets of information across 
network 160. In one embodiment, networking device 272 is a cable modem, but in 
other embodiments, networking device 272 can be a DSL (Digital Subscriber Line) 

20 modem, an ISDN (Integrated Services Digital Network) terminal adapter, an Ethernet 

interface device, or any other type of LAN, WAN, or broadband device. In one 
embodiment, networking device 272 supports communication between computer 110 
and another computer system over a standard telephone line. In another embodiment, 
networking device 272 attaches to a dedicated cable. In another embodiment, through 

25 networking device 272 computer 110 can access other sources such as a server, an 

electronic bulletin board, and the Internet or World Wide Web. 
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Networking device 272 is capable of communicating across network 160 using 
a TCP/IP (Transmission Control Protocol/Internet Protocol) or UDP/EP (User 
Datagram Protocol/Internet Protocol) connection, but in other embodiments, any 
suitable communications protocol can be used, for example the ISO/OSI (International 
5 Organization for Standardization/Open Systems Interconnection) model. 

Pattern filter 274 interrogates the packets of information that are received by 
networking device 272 and forwards to port filter 276 only those packets containing 
data in selected fields that match data associated with computer 1 10. Examples of the 
selected fields are the network address and the protocol identifier, but any appropriate 
10 field or fields can be used. All other packets are either discarded or forwarded on to 
their proper destination on network 160. 

Port filter 276 is programmed by program information 264 to filter received 
packets based on port number and to present only those packets to computer 1 1 0 that 
contain port numbers matching the port number of application 260. Although two 
1 5 port filters are shown in Fig. 2, in another embodiment any number can be present 
corresponding to the number of applications executing on host computer 110 
associated with a port number. In still another embodiment, only one port filter exists 
in network adapter 150, which handles all applications in host computer 110. 

In one embodiment, port filter 276 is implemented via an unillustrated 
20 processor and memory, and program information 264 is downloaded from computer 
110 into the port-filter memory and executed by the port-filter processor. In another 
embodiment, program information 264 contains data about the port numbers being 
used by applications 260, and this data is interpreted by instructions executing on the 
processor of port filter 276. In still another embodiment, port filter 276 is 
25 implemented by control circuitry though the use of logic gates, programmable logic 

devices, or other hardware components, and program information 264 contains data 
that is used by the control circuitry. The operation of port filter 276 is further 
described with reference to Figs. 4 and 5. 

Attorney Docket No, 884.336US1 8 Client Ref. No. P9900 



Network 160 can include a plurality of networks, each of which can include a 
plurality of individual computers. In one embodiment, network 160 and remote 
computer 188 are located a great geographic distance from computer 110, but in 
another embodiment they can be in the same room or even on the same desktop. 
5 Network adapter 150 can be connected to network 160 via a standard telephone line, a 
dedicated cable, or a wireless communications link. 

The configuration depicted in Fig. 1 is but one possible implementation of the 
components depicted in Fig. 2. Portable computers, laptop computers, and network 
computers or Internet appliances are other possible configurations. The hardware 

10 depicted in Fig. 2 may vary for specific applications. For example, other peripheral 
devices such as optical-disk media, audio adapters, or chip programming devices, 
such as PAL or EPROM programming devices can be used in addition to or in place 
of the hardware already depicted. Thus, an embodiment of the invention can apply to 
any hardware configuration that allows filtering of packets, regardless of whether the 

15 hardware configuration is a complicated, multi-user computing apparatus, a single- 
user workstation, or a network appliance that does not have non- volatile storage of its 
own. 

As will be described in detail below, aspects of an embodiment pertain to 
specific method elements implementable on computers. In another embodiment, the 
20 invention can be implemented as a computer program product for use with a 

computer. The programs defining the functions of the embodiment can be delivered 
to computer 1 10 or network adapter 150 via a variety of signal-bearing media, which 
include, but are not limited to: 

(1) information permanently stored on non-writeable storage media (e.g., 
25 read-only memory devices within a computer such as CD-ROM disks) readable by an 
unillustrated CD-ROM drive; 
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(2) alterable information stored on writeable storage media (e.g., floppy disks 
within diskette drive 122, tapes within tape drive 124, or disks within hard-disk drive 
123); or 

(3) information conveyed by a communications media, such as through a 
5 computer or telephone network including wireless communications. 

Such signal-bearing media, when carrying computer-readable instructions that 
direct the functions of the present invention, represent embodiments of the present 
invention. 

Fig. 3 depicts a flowchart that describes a method at host computer 110, 
10 according to an embodiment of the invention. Control begins at block 300. Control 
then continues to block 310 where controller 262 detects that application 260 has been 
started. Control then continues to block 320 where controller 262 detects the port 
number associated with application 260. Control then continues to block 330 where 
controller 262 selects the program information 264 based on the application detected 
1 5 in block 310 and the port determined in block 320. In one embodiment, program 

information 264 includes multiple port-filter programs containing executable 
instructions and data, each tailored for a particular port. In another embodiment, there 
is only one port-filter program, which contains executable instructions and data 
regarding each application 260 and its associated port number. In still another 
20 embodiment, program information 264 contains data regarding the applications and 
port numbers, but program information 264 does not contain executable instructions. 

Control then continues to block 340 where controller 262 sends the program 
information selected at block 330 to port filter 276. Control then continues to block 
350 where controller 262 causes computer 1 10 to enter a power-managed state when 
25 there are no received packets. During a power-managed state, computer 110 

consumes a reduced amount of power. Control then continues to block 360 where 
controller 262 receives a wake-up signal from network adapter 150 and in response 
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changes computer 110 from its power-managed state to its normal, operating state. 
Control then continues to block 399 where the function returns. 

Fig. 4 depicts a flowchart that describes a method at port filter 276, according 
to an embodiment of the invention. Control begins at block 400. Control then 
5 continues to block 410 where port filter 276 receives program information 264 from 
host computer 1 10. Control then continues to block 420 where, in one embodiment, 
port filter 276 initializes its functions with the data of program information 264. In 
another embodiment, port filter 276 loads the executable instructions of program 
information 264. Control then continues to block 499 where the function returns. 

10 Fig. 5 depicts a flowchart that describes a method at port filter 276, according 

to an embodiment of the invention. Control begins at block 500. Control then 
continues to block 510 where port filter 276 receives a directed packet from remote 
computer 188 via network 160, networking device 272, and pattern filter 274. Control 
then continues to block 520 where port filter 276 determines whether the port number 

1 5 in the received packet matches the port number assigned to an application executing 
on host computer 110. Port filter 276 carries out this determination using program 
information 264, which was previously loaded as described with reference to Fig. 4. 
Referring again to Fig. 5, if the determination at block 520 is false, then control 
continues to block 530 where port filter 276 discards the received packet. Control 

20 then returns to block 5 10, as previously described above. 

If the determination at block 520 is true, then control continues to block 540 
where port filter 276 sends a wake-up message to host computer 110. Control then 
continues to block 599 where the function returns. 
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